chat-sidebar.scss 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. .chat-sidebar {
  2. display: flex;
  3. flex-direction: column;
  4. height: 100%;
  5. background: var(--bg-page);
  6. position: relative;
  7. .chat-header {
  8. display: flex;
  9. align-items: center;
  10. justify-content: space-between;
  11. padding: 2px 12px;
  12. background: var(--bg-subtle);
  13. border-bottom: 1px solid var(--border-default);
  14. flex-shrink: 0;
  15. .chat-header-title {
  16. font-size: 0.875rem;
  17. font-weight: 600;
  18. color: var(--text-primary);
  19. }
  20. .chat-header-actions {
  21. display: flex;
  22. align-items: center;
  23. gap: 4px;
  24. .chat-participant-count {
  25. display: flex;
  26. align-items: center;
  27. gap: 4px;
  28. padding: 4px 8px;
  29. border: none;
  30. background: transparent;
  31. font-size: 0.75rem;
  32. color: var(--text-secondary);
  33. cursor: pointer;
  34. border-radius: 4px;
  35. transition: background 0.15s, color 0.15s;
  36. svg {
  37. font-size: 0.8125rem;
  38. }
  39. span {
  40. font-weight: 500;
  41. }
  42. &:hover {
  43. background: var(--border-default);
  44. color: var(--text-primary);
  45. }
  46. }
  47. > button:not(.chat-participant-count),
  48. .chat-menu-wrapper > button {
  49. display: flex;
  50. align-items: center;
  51. justify-content: center;
  52. width: 32px;
  53. height: 32px;
  54. border: none;
  55. background: transparent;
  56. cursor: pointer;
  57. color: var(--text-secondary);
  58. border-radius: 4px;
  59. transition: background 0.15s, color 0.15s;
  60. &:hover {
  61. background: var(--border-default);
  62. color: var(--text-primary);
  63. }
  64. }
  65. }
  66. .chat-menu-wrapper {
  67. position: relative;
  68. }
  69. .chat-menu {
  70. position: absolute;
  71. top: 100%;
  72. right: 0;
  73. min-width: 150px;
  74. background: var(--bg-page);
  75. border: 1px solid var(--border-default);
  76. border-radius: 3px;
  77. z-index: 10;
  78. overflow: hidden;
  79. button {
  80. display: flex;
  81. align-items: center;
  82. gap: 8px;
  83. width: 100%;
  84. padding: 10px 14px;
  85. border: none;
  86. background: transparent;
  87. cursor: pointer;
  88. font-size: 0.8125rem;
  89. color: var(--text-primary);
  90. text-align: left;
  91. transition: background 0.15s;
  92. svg {
  93. width: 14px;
  94. color: var(--text-muted);
  95. }
  96. &:hover {
  97. background: var(--bg-subtle);
  98. }
  99. &:disabled {
  100. color: var(--border-strong);
  101. cursor: not-allowed;
  102. svg {
  103. color: var(--border-strong);
  104. }
  105. &:hover {
  106. background: transparent;
  107. }
  108. }
  109. }
  110. }
  111. }
  112. .chat-messages {
  113. flex: 1;
  114. overflow-y: auto;
  115. padding: 8px 12px;
  116. display: flex;
  117. flex-direction: column;
  118. gap: 4px;
  119. &::-webkit-scrollbar {
  120. width: 4px;
  121. }
  122. &::-webkit-scrollbar-thumb {
  123. background: var(--border-strong);
  124. border-radius: 2px;
  125. }
  126. .chat-system {
  127. text-align: center;
  128. font-size: 0.75rem;
  129. color: var(--text-muted);
  130. padding: 4px 0;
  131. }
  132. .chat-message {
  133. display: flex;
  134. align-items: baseline;
  135. gap: 6px;
  136. padding: 3px 0;
  137. line-height: 1.4;
  138. word-break: break-word;
  139. .chat-message-time {
  140. font-size: 0.625rem;
  141. color: var(--text-muted);
  142. flex-shrink: 0;
  143. }
  144. .chat-message-name {
  145. font-size: 0.8125em;
  146. font-weight: 600;
  147. color: var(--text-secondary);
  148. flex-shrink: 0;
  149. max-width: 80px;
  150. overflow: hidden;
  151. text-overflow: ellipsis;
  152. white-space: nowrap;
  153. }
  154. .chat-message-content {
  155. font-size: 1em;
  156. color: var(--text-primary);
  157. }
  158. }
  159. }
  160. .chat-input-area {
  161. flex-shrink: 0;
  162. border-top: 1px solid var(--border-default);
  163. padding: 8px 10px;
  164. background: var(--bg-elevated);
  165. .chat-input-row {
  166. display: flex;
  167. gap: 6px;
  168. input {
  169. flex: 1;
  170. padding: 8px 10px;
  171. border: 1px solid var(--border-default);
  172. border-radius: 4px;
  173. font-size: 0.8125rem;
  174. outline: none;
  175. transition: border-color 0.15s;
  176. &:focus {
  177. border-color: #F7931A;
  178. }
  179. &:disabled {
  180. background: var(--bg-subtle);
  181. color: var(--text-muted);
  182. }
  183. }
  184. button {
  185. display: flex;
  186. align-items: center;
  187. justify-content: center;
  188. width: 36px;
  189. height: 36px;
  190. border: none;
  191. background: var(--brand-orange);
  192. color: #fff;
  193. border-radius: 4px;
  194. cursor: pointer;
  195. flex-shrink: 0;
  196. transition: background 0.15s;
  197. &:hover {
  198. background: var(--brand-orange-hover);
  199. }
  200. &:disabled {
  201. background: var(--border-strong);
  202. cursor: not-allowed;
  203. }
  204. }
  205. }
  206. .chat-login-notice {
  207. text-align: center;
  208. font-size: 0.8125rem;
  209. color: var(--text-muted);
  210. padding: 2px 0;
  211. a {
  212. color: var(--brand-orange);
  213. font-weight: 600;
  214. text-decoration: underline;
  215. &:hover {
  216. color: var(--brand-orange-hover);
  217. }
  218. }
  219. }
  220. }
  221. // 참여자 목록 오버레이
  222. .chat-participants-overlay {
  223. position: absolute;
  224. top: 0;
  225. left: 0;
  226. right: 0;
  227. bottom: 0;
  228. background: var(--overlay-color);
  229. z-index: 11;
  230. }
  231. // 참여자 목록 패널
  232. .chat-participants-dialog {
  233. position: absolute;
  234. top: 50%;
  235. left: 50%;
  236. transform: translate(-50%, -50%);
  237. width: calc(100% - 24px);
  238. max-height: 60%;
  239. background: var(--bg-page);
  240. border-radius: 8px;
  241. box-shadow: 0 8px 24px var(--shadow-color);
  242. overflow: hidden;
  243. z-index: 12;
  244. .chat-participants-header {
  245. display: flex;
  246. align-items: center;
  247. justify-content: space-between;
  248. padding: 12px 16px;
  249. border-bottom: 1px solid var(--border-default);
  250. background: var(--bg-subtle);
  251. h3 {
  252. font-size: 0.875rem;
  253. font-weight: 600;
  254. color: var(--text-primary);
  255. margin: 0;
  256. }
  257. button {
  258. display: flex;
  259. align-items: center;
  260. justify-content: center;
  261. width: 28px;
  262. height: 28px;
  263. border: none;
  264. background: transparent;
  265. cursor: pointer;
  266. font-size: 1.25rem;
  267. color: var(--text-secondary);
  268. border-radius: 4px;
  269. &:hover {
  270. background: var(--border-default);
  271. color: var(--text-primary);
  272. }
  273. }
  274. }
  275. .chat-participants-list {
  276. list-style: none;
  277. margin: 0;
  278. padding: 0;
  279. overflow-y: auto;
  280. max-height: calc(100% - 52px);
  281. li {
  282. display: flex;
  283. align-items: center;
  284. gap: 8px;
  285. padding: 10px 16px;
  286. font-size: 0.8125rem;
  287. color: var(--text-primary);
  288. border-bottom: 1px solid var(--bg-subtle);
  289. &:last-child {
  290. border-bottom: none;
  291. }
  292. .chat-participant-icon {
  293. color: var(--text-muted);
  294. font-size: 0.75rem;
  295. }
  296. }
  297. .chat-participants-empty {
  298. justify-content: center;
  299. color: var(--text-muted);
  300. padding: 24px 16px;
  301. }
  302. .chat-participants-guest {
  303. color: var(--text-muted);
  304. font-style: italic;
  305. }
  306. }
  307. }
  308. }